<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="${package.Mapper}.${table.mapperName}">

<#if enableCache>
    <!-- 开启二级缓存 -->
    <cache type="${cacheClassName}"/>

</#if>
<#if baseResultMap>
    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="${package.Entity}.${entity}">
<#list table.fields as field>
<#if field.keyFlag><#--生成主键排在第一位-->
        <id column="${field.name}" property="${field.propertyName}" />
</#if>
</#list>
<#list table.commonFields as field><#--生成公共字段 -->
        <result column="${field.name}" property="${field.propertyName}" />
</#list>
<#list table.fields as field>
<#if !field.keyFlag><#--生成普通字段 -->
        <result column="${field.name}" property="${field.propertyName}" />
</#if>
</#list>
    </resultMap>

</#if>
<#if baseColumnList>
    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
<#list table.commonFields as field>
        ${field.columnName},
</#list>
        ${table.fieldNames}
    </sql>

</#if>
    <insert id="insert" parameterType="${package.Entity}.${table.entityName}"
    useGeneratedKeys="true" keyProperty="id">
        INSERT INTO ${table.name}
            (<#list table.fields as field><#if !field.keyFlag&&field_has_next&&field_index!=1>,`${field.name}`<#elseif !field.keyFlag&&field_has_next&&field_index==1 >`${field.name}`</#if></#list>)
        values(<#list table.fields as field><#if !field.keyFlag &&field.name!="is_deleted"&&field_index!=1>,
        <#noparse>#</#noparse>{${table.entityPath}.${field.propertyName}}<#elseif !field.keyFlag &&field.name!="is_deleted"><#noparse>#</#noparse>{${table.entityPath}.${field.propertyName}}</#if></#list>)
    </insert>

    <update id="update" parameterType="${package.Entity}.${table.entityName}">
        UPDATE ${table.name}
        <set><#list table.fields as field><#if !field.keyFlag&&field.name!="create_time"&&field.name!="is_deleted">
            <if test="${table.entityPath}.${field.propertyName}!=null and ${table.entityPath}.${field.propertyName}!='' ">
                `${field.name}`=<#noparse>#</#noparse>{${table.entityPath}.${field.propertyName}},
            </if>
                </#if>
            </#list>
        </set>
        WHERE id=<#noparse>#</#noparse>{<#list table.fields as field><#if field.keyFlag>${table.entityPath}.${field.propertyName}</#if></#list>}
    </update>
</mapper>
